# Single Network Structure for Stuck-at and Bridging Fault Analysis and Diagnosis of Exclusive-OR Sum of Products Reed-Muller Canonical Circuits

Geetha V., Devarajan N. and Neelakantan P. N.

**Abstract**— In this paper, a testable design with good fault identification capability is used for analysis and diagnosis of AND-bridging and double stuck-at faults in Exclusive-OR Sum of Product Reed-Muller canonical circuits, independent of the function for a given number of inputs. Factors of identifiability and distinguishability have been defined and determined. Further, a compact method of representing the circuit outputs has been adopted for ease of tabulation and comparison. Simulations of AND-bridging and Double stuck-at faults for a few random functions have been carried out through MATLAB coding. From the test results, it was found that the fault detection for the set of random functions was more than 90% for most of the functions except few cases, with just n+5 test vectors compared to 2<sup>n</sup> test vectors required for conventional testing. The location of the fault can also be diagnosed through the output sets.

Index Terms— Reed-Muller Canonical Form, Exclusive-OR Sum of Products, Testable Realization, AND-bridging fault ,Double stuck-at fault

# **1** INTRODUCTION

 ${\sf T}$ HE faults in digital circuits can be classified broadly as single stuck-at-faults, multiple stuck-at-faults, stuck-open faults, stuck-on faults, bridging faults, path delay faults, transient faults etc. Any arbitrary logic function, in general, can be expressed in Reed-Muller Canonical (RMC) form as  $F = (a0 \oplus a1x1^* \oplus a2 x2^* \oplus ... \oplus anxn^* \oplus an+1 x1^* x2^* \oplus ... \oplus$ am x1<sup>\*</sup> x2<sup>\*</sup>...xn<sup>\*</sup>)where,  $x_n^*$  can be  $x_n$  or its complement,  $a_n$  is either 0 or 1 and  $m = 2^{n}-1$ . However, there can be variations in such forms. The different types are Fixed Polarity RMC (FPRM), Positive Polarity RMC (PPRM), Generalized RMC (GRM) and Exclusive-OR Sum-of-Products RMC (ESOP RM). The FPRM has a restriction that the variables in any of the product terms have to be of the same type namely complementary or non-complementary. For PPRM, the complementary form of variables is not allowed. The GRM may contain both complementary and non-complementary types but the combination of the variables should be unique. The ESOP form does not have any such restriction. Also the ESOP form has the least number of product terms and hence needs the least number of AND gates and is very much suitable for hardware implementation.

Extensive research has been carried out in the field of testing of digital circuits to reduce the number of input vectors. The cardinality of the test vectors proposed by many authors becomes prohibitively excessive for large number of input variables. It was demonstrated that Single stuck-at fault detection can be achieved with only n+5 test vectors [6]. The same structure was extended for OR-bridging fault analysis and is explained in [15] and [16]. In this paper, it is shown through Matlab simulations that AND-bridging and Double stuck-at fault detection and diagnosis could also be achieved with the same n+5 test vectors considering all input lines, control lines and intermediate gate outputs.

Two quantitative indices, called identifiability factor and distinguishability factor are considered for comparison of the testability nature of given circuits. The identifiability factor is defined as the ratio of the number of faults correctly identified by the test set to the total number of possible faults of the type considered. The existence of faults can be recognized from the set of outputs measured which will be different from the faultfree circuit. The distinguishability factor pertains to the identical set of outputs among different faults, but the output set of each being very much different from the non-faulty case. The existence of even a small percentage of distinguishability may not mean the circuit is not reliable, since it is still possible to identify the faulty condition of the circuit and take appropriate remedial action. The set of binary values for an output is converted into its decimal equivalent for convenience in comparison and ease of tabulation.

# 2 LITERATURE SURVEY

A PPRM network for detection of stuck-at faults with a universal test set of size n+4, n being the number of data inputs, was proposed in [1]. Though quite good for self-testing, the method is economical only for the specified form, which obviously has more number of product terms than the other forms in most cases. Multiple stuck-at fault detection for ESOP circuits was carried out in [2]. However, since the cardinality is  $2n+6+\sum nC_e$ , e = 0 to j, the order of ESOP expression, the test set is not universal and also is too large to be practical for large input functions. Stuck-at and bridging faults with a universal test set for PPRM network has been reported in [3]. Multiple fault detecting GRM realizations was proposed in [4].

International Journal of Scientific & Engineering Research Volume 4, Issue3, March-2013 ISSN 2229-5518

Reference [5] described an ESOP implementation with a universal test set of size n+6 for single stuck-at faults only. In [6] it was demonstrated that single stuck-at fault detection can be achieved with only n+5 test vectors. It was shown in [7] that 2n+s+3 test vectors are required for single stuck-at fault detections in GRM / ESOP circuits while 2n+s vectors are required for detection of AND/OR-bridging faults in such circuits , where s is the number of product terms in the logic function. Here too, the test set is not universal as it depends on s, the number of product terms of the function. References [8], [9] proved that a test sequence of length 2n+8 vectors is sufficient to detect all single stuck-at and bridging faults. Two new methods, each with a small modification in this scheme with ESOP RMC circuits had been proposed for analysis and diagnosis of single stuck-at faults [10], [11].

In [12],[13],[14], it was demonstrated how the RMC forms help in the detection of various digital faults and how to determine the best polarity among them. It was proved that test vectors for multiple fault detection and diagnosis in digital circuits could be generated using Neural Network with different training algorithms [15]. Reference [16] proposed a new test pattern generation algorithm using Neural Network which requires additional gates. The analysis and diagnosis of OR-bridging faults in any of the pairs of data and control lines and OR-bridging faults including intermediate gate outputs of the ESOP RMC circuits was proposed in [17], [18]. This paper is an extension of [18] which also analyses the ANDbridging and double stuck-at faults of the ESOP RMC circuits with minimal test vectors.

## **3** MATERIALS AND METHODS

#### 3.1 Network Structure

The network structure of the scheme is the same as that proposed in [6] and is shown in Fig. 1. It comprises a literal complementing XOR block, an AND block, an XOR function tree block, which implements the required logic function as also two additional outputs  $O_1$  and  $O_2$  obtained through a separate AND gate and an OR gate. The actual data inputs to the system are  $x_1, x_2 \dots x_n$ . Additionally, the scheme requires four control inputs  $c_1$  to  $c_4$ . The literal-complementing block produces the complements of the literals used in the function. Only those literals appearing in complemented form require an XOR gate in this block.

The literals of each product term  $P_1$ ,  $P_2$ ,  $..P_m$  are combined through an AND gate and hence the number of AND gates required is the same as the number of product terms in the logic function. Further, each of the AND gates of this block has an additional input from one of the control lines depending on the number of gates used in the XOR tree block producing the final function F. Finally, all the data and complementary gate outputs are applied to a separate AND gate and an OR gate, producing auxiliary outputs  $O_1$  and  $O_2$ , to aid in the detection of faults which cannot be differentiated by the main function output F alone.



Fig.1 Generalised Network structure



Fig.2 Control Input Determination

The required control lines are determined as illustrated above (Fig. 2). Draw the XOR gate tree for the required product terms of the given function. Assign the numerals 1, 2 and 3 respectively to the two inputs and the output of the final XOR gate producing the function output F. Consider each XOR gate connected to the inputs of the final XOR gate considered. Assign the outputs of these XOR gates with the same numbers as the inputs of the final XOR gate. If the output of the XOR gate considered is 1, then assign 2 and 3 to its inputs; else if the output is numbered 2, assign 3 and 1 to its input. Now consider the next earlier input stage and assign the numerals in the similar manner according to the output points connected.

#### 3.2 Test Vectors

The test set has (n+5) vectors; each of the vectors is (n+4) long, 'n' being the number of data inputs. The first four columns of the matrix represent the control inputs  $c_1$  to  $c_4$  while the remaining n columns that of the data inputs are  $x_1$  to  $x_n$ . The generalized test set is shown in Table 1.

TABLE 1 GENERALIZED TEST SET

|       |    |    | -  | -              | _  | _ |    |
|-------|----|----|----|----------------|----|---|----|
| $c_1$ | c2 | C3 | C4 | $\mathbf{x}_1$ | x2 |   | Xn |
| 0     | 0  | 0  | 0  | 0              | 0  |   | 0  |
| 0     | 0  | 1  | 1  | 1              | 1  |   | 1  |
| 0     | 1  | 0  | 1  | 1              | 1  |   | 1  |
| 0     | 1  | 1  | 1  | 1              | 1  |   | 1  |
| 0     | 1  | 1  | 1  | 0              | 1  |   | 1  |
| 0     | 1  | 1  | 1  | 1              | 0  |   | 1  |
| 0     | 1  | 1  | 1  | 1              | 1  |   | 1  |
|       |    |    |    |                |    |   |    |
|       |    |    |    |                |    |   |    |
|       |    |    |    |                |    |   |    |
| 0     | 1  | 1  | 1  | 1              | 1  |   | 0  |
| 1     | 0  | 0  | 0  | 0              | 0  |   | 0  |
|       |    |    | -  | -              |    | - |    |

#### 3.3 Algorithm

- 1. Set up the circuit as in Fig. 1.
- 2. Determine and connect the control lines  $c_1$  to  $c_4$  as explained.
- 3. Apply the test vectors as given in Table 1, one by one.
- 4. For each test vector, determine the fault free outputs F,  $O_1$  and  $O_2$ .
- 5. Obtain the decimal equivalents of each of the above binary output sets.
- Simulate the AND-bridging and double-stuck-at faults with various possible combinations of the control inputs, data inputs and intermediate gate outputs and get the corresponding decimal outputs.
- 7. Compare the set of outputs with the predetermined fault-free outputs.
- 8. If the two output sets match exactly, it implies that a fault, if present, is not identifiable or detectable; else, the fault is a detectable one.
- 9. Repeat steps 4 to 8 for all the ten functions and for the specified faults.
- 10. Calculate the identifiability factor and distinguishability factor for each type of fault.

#### **4** RESULTS AND DISCUSSION

The following ten random functions were considered and AND-bridging and double stuck-at faults are simulated using MATLAB coding and the consolidated results are tabulated in Tables 4 and 9.

 $\mathsf{F}_1 = \mathsf{x}_1 \bigoplus \mathsf{x}_2 \mathsf{x}_3 \bigoplus \mathsf{x}_1' \mathsf{x}_2 \mathsf{x}_3$ 

 $F_2 = x_1 x_2 \bigoplus x_2' x_3 \bigoplus x_3' x_4 \bigoplus x_1 x_2 x_3$ 

 $F_3 = x_1' \oplus x_2 x_3' x_4 \oplus x_3 x_4' \oplus x_2' x_3 \oplus x_1 x_4 x_5$ 

 $\mathsf{F}_4 = x_1 x_2{'} \oplus x_2 x_3 x_4{'} \oplus x_4 x_5{'} x_6 \oplus x_2 x_5 \oplus x_2{'} x_5{'} \oplus x_3{'} x_2 x_1 \oplus x_4 x_6$ 

 $F_{5} = x_{1}'x_{2}x_{3} \bigoplus x_{4}x_{5}x_{6} \bigoplus x_{4}'x_{6}'x_{7} \bigoplus x_{3}x_{5}x_{7}$ 

 $\mathsf{F}_6 = x_1 x_2 ' x_3 \oplus x_4 ' x_5 x_6 ' \oplus x_7 x_8 ' \oplus ' \oplus x_1 ' x_6 \oplus x_3 ' x_4 \oplus x_1 x_5$ 

 $\oplus x_4 x_5' \oplus x_5 x_7 \oplus x_8 x_3 x_1 \oplus x_3 x_5' x_8$ 

 $\begin{array}{l} F_{7}=x_{1}x_{2}'x_{3}'\oplus x_{4}x_{5}'x_{6}\oplus x_{7}'x_{8}x_{9}\oplus x_{1}'x_{4}'x_{9}'\oplus x_{2}x_{5}'\oplus x_{3}x_{5}\\ F_{8}=x_{1}'x_{2}x_{3}'\oplus x_{4}'x_{5}'x_{6}\oplus x_{7}x_{8}'x_{9}'\oplus x_{10}\oplus x_{6}'x_{7}\oplus x_{8}x_{10}\\ F_{9}=x_{1}\oplus x_{2}'x_{3}x_{4}'\oplus x_{5}'x_{6}x_{7}'\oplus x_{8}x_{9}x_{10}\oplus x_{10}'x_{11}\oplus x_{1}x_{3}x_{9}\\ F_{10}=x_{1}'x_{2}\oplus x_{3}x_{4}'x_{5}\oplus x_{6}x_{7}'x_{8}x_{9}\oplus x_{10}x_{11}'x_{12}\oplus x_{1}x_{2}x_{3}'\oplus x_{4}'x_{7}\\ \text{As an illustration, the three variable function} \end{array}$ 

 $F_1 = x_1 \oplus x_2 x_3 \oplus x_1' x_2 x_3$  is considered. The network structure and the set of test vectors for the function  $F_1$  is shown in Fig. 3 and Table 2 respectively.



Fig. 3 Circuit for  $F = x_1 \oplus x_2 x_3 \oplus x_1' x_2 x_3$ 

TABLE 2 TEST VECTORS FOR  $F = x_1 \oplus x_2 x_3 \oplus x_1' x_2 x_3$ 

|       | -                     | -  | -  | -              | -              | -  |
|-------|-----------------------|----|----|----------------|----------------|----|
| $c_1$ | <b>C</b> <sub>2</sub> | C3 | C4 | $\mathbf{x}_1$ | $\mathbf{X}_2$ | X3 |
| 0     | 0                     | 0  | 0  | 0              | 0              | 0  |
| 0     | 0                     | 1  | 1  | 1              | 1              | 1  |
| 0     | 1                     | 0  | 1  | 1              | 1              | 1  |
| 0     | 1                     | 1  | 1  | 1              | 1              | 1  |
| 0     | 1                     | 1  | 1  | 0              | 1              | 1  |
| 0     | 1                     | 1  | 1  | 1              | 0              | 1  |
| 0     | 1                     | 1  | 1  | 1              | 1              | 0  |
| 1     | 0                     | 0  | 0  | 0              | 0              | 0  |

## 4.1 AND-Bridging Faults

The bridging faults are considered as a special case of multiple faults. A detailed numerical illustration for three variable AND-bridging faults is given below.

Function considered:  $F_1 = x1 \oplus x_2x_3 \oplus x_1'x_2x_3$ 

Fault-free output set {F,  $O_1$ ,  $O_2$ } = {126, 112, 127}

The outputs of AND-bridging faults at lines  $c_1$  in combination with  $c_2$ ,  $c_3$ ,  $c_4$ ,  $x_1$ ,  $x_2$ ,  $x_3$ ,  $zI_1$ ,  $za_1$ ,  $za_2$ ,  $za_3$ ,  $zx_1$  and  $zx_2$  are tabulated in Table 3(a) and 3(b).

IJSER © 2013 http://www.ijser.org

TABLE 3(a) AND-BRIDGING FAULTS INVOLVING C1 FOR FUNCTION F1

| 2  | C1 C2 | C1 C3 | C1 C4 | C <sub>1</sub> X <sub>1</sub> | C1X2 | C1 X3 |
|----|-------|-------|-------|-------------------------------|------|-------|
| F  | 126   | 120   | 6     | 120                           | 86   | 86    |
| O, | 112   | 112   | 112   | 0                             | 0    | 0     |
| 0, | 126   | 126   | 126   | 126                           | 126  | 126   |

| -     | ~ | <i>/</i> \ |
|-------|---|------------|
| TABLE | 3 | (b)        |

| 8<br> | c, zl | c <sub>1</sub> za <sub>1</sub> | c, za <sub>2</sub> | c, za, | c <sub>1</sub> zx <sub>1</sub> | C <sub>1</sub> ZX <sub>2</sub> |
|-------|-------|--------------------------------|--------------------|--------|--------------------------------|--------------------------------|
| F     | 46    | 40                             | 6                  | 46     | 80                             | 0                              |
| 0,    | 0     | 112                            | 112                | 112    | 112                            | 112                            |
| O2    | 127   | 126                            | 126                | 126    | 126                            | 126                            |

Total No. of fault location pair combinations

=  $(nc+nx+nzl+nza+nzx) C_2 = 13C_2 = 78$ Total number of possible bridging faults for the given three variable function used is 78.

From the simulation results it was found that the number of unidentifiable faults as 11.

: The Identifiability Factor is

(78 - 11) / 78\*100 = 85.90%.

For the given example, the output sets that get repeated are as follows:

| repeated are as | follows:   |        |     |    |       |       |
|-----------------|------------|--------|-----|----|-------|-------|
| {6, 112, 126}   | 2          | times  |     |    |       |       |
| {62, 112, 127}  | 5          | times  |     |    |       |       |
| {80, 112, 127}  | 2          | times  |     |    |       |       |
| {80, 112, 127}  | 2          | times  |     |    |       |       |
| {86, 0, 126}    | 2          | times  |     |    |       |       |
| {86, 80, 127}   | 2          | times  |     |    |       |       |
| {86, 112, 127}  | 5          | times  |     |    |       |       |
| {94, 112, 127}  | 2          | times  |     |    |       |       |
| {118, 112, 126} | 5          | times  |     |    |       |       |
| {118, 112, 127} | 2          | times  |     |    |       |       |
| {120, 112, 127} | 4          | times  |     |    |       |       |
| {126, 48, 127}  | 3          | times  |     |    |       |       |
| {126, 80, 126}  | 3          | times  |     |    |       |       |
| {126, 80, 127}  | 2          | times  |     |    |       |       |
| Thus totally    | repetition | occurs | for | 41 | fault | locat |

Thus totally repetition occurs for 41 fault location combinations. Hence overall distinguishability factor is

(78 - 41) / 78 \* 100 = 47.44%.

However, when the individual cases are considered the distinguishability factor can be seen to be appreciably high as seen below:

Same output set of {120, 112, 127} for the following fault combinations

AND-bridging fault at c<sub>3</sub>, za<sub>3</sub> lines

AND-bridging fault at za<sub>1</sub>, za<sub>3</sub> lines

AND-bridging fault at za2, zx1 lines

AND-bridging fault at za2, zx2 lines

The distinguishability for this set is $(78 - 4) / 78 \times 100 = 94.87\%$ . Similarly, the output set {126, 80, 126} occurs 3 times, for which the distinguishability factor is  $(78 - 3) / 78 \times 100 = 96.15\%$ . Further, the location of fault can also be easily diagnosed from the output set. For instance if the output set is {120, 112, 127} then the fault condition would be one of the four cases discussed above involving c<sub>3</sub>, za<sub>1</sub>, za<sub>2</sub>, za<sub>3</sub>, zx<sub>1</sub>, zx<sub>2</sub> and hence those lines only need to be checked.

Similarly, the fault simulations were carried out for the remaining nine random functions and the results are tabulated in Table 4.

TABLE 4 CONSOLIDATED RESULTS FOR AND-BRIDGING FAULTS

| S.No. | Function         | No. of Data<br>Inputs | Total Possible<br>Faults | Identifiability<br>Factor (%) | Distinguishabilit<br>y<br>Factor (%) |
|-------|------------------|-----------------------|--------------------------|-------------------------------|--------------------------------------|
| 1     | F <sub>1</sub>   | 3                     | 78                       | 85.90                         | 47.44                                |
| 2     | F <sub>2</sub>   | 4                     | 136                      | 95.59                         | 36.76                                |
| 3     | F <sub>3</sub>   | 5                     | 231                      | 89.18                         | 47.62                                |
| 4     | F4               | 6                     | 351                      | 90.88                         | 52.42                                |
| 5     | $\mathbf{F}_{5}$ | 7                     | 210                      | 86.19                         | 48.10                                |
| 6     | F.               | 8                     | 820                      | 91.59                         | 58.66                                |
| 7     | $F_{7}$          | 9                     | 465                      | 91.40                         | 47.74                                |
| 8     | F                | 10                    | 496                      | 90.52                         | 33.06                                |
| 9     | F <sub>9</sub>   | 11                    | 465                      | 90.75                         | 38.49                                |
| 10    | F <sub>10</sub>  | 12                    | 496                      | 89.11                         | 47.98                                |
|       | Av               | erage                 |                          | 90.11                         | 45.83                                |

#### 4.2 Double Stuck-at Faults

Double Stuck-at faults can occur quite frequently at the adjacent lines of the circuit. The network structure and test vectors are the same as above. However, in the test procedure, two lines at a time are considered and made to be stuck-at-0 or stuck-at-1 and simulated. Since two lines are involved, four possible combinations, viz. (0,0), (0,1), (1,0) and (1,1) with one of the lines as c1 are simulated and tabulated in Tables 5(a),5(b),6(a),6(b),7(a),7(b),8(a) and 8(b).

#### TABLE 5(a)

DOUBLE STUCK-AT FAULTS OUTPUTS FOR FUNCTION  $F_1$  with  $c_1$  as one of the lines for 0,0 combination

|    | C, C2 | C, C | C, C, | C, X | C, X, | C, X |
|----|-------|------|-------|------|-------|------|
| F  | 126   | 120  | 6     | 120  | 86    | 86   |
| 0, | 112   | 112  | 112   | 0    | 0     | 0    |
| 0, | 126   | 126  | 126   | 126  | 126   | 126  |

International Journal of Scientific & Engineering Research Volume 4, Issue3, March-2013 ISSN 2229-5518

TABLE 5(b)

|    | c <sub>1</sub> zl <sub>1</sub> | c, za, | c, za <sub>2</sub> | $c_1 z a_3$ | C <sub>1</sub> ZX <sub>1</sub> | C <sub>1</sub> ZX <sub>2</sub> |
|----|--------------------------------|--------|--------------------|-------------|--------------------------------|--------------------------------|
| F  | 46                             | 40     | 6                  | 46          | 80                             | 0                              |
| 0, | 0                              | 112    | 112                | 112         | 112                            | 112                            |
| 0, | 126                            | 126    | 126                | 126         | 126                            | 126                            |

|  | TABL | Е 6 | (a) | ) |
|--|------|-----|-----|---|
|--|------|-----|-----|---|

DOUBLE STUCK-AT FAULTS OUTPUTS FOR FUNCTION  $F_1$ WITH  $C_1$  AS ONE OF THE LINES FOR 0,1 COMBINATION

|                | c, zl | c, za | c, za, | c, za, | c,zx, | $c_1 Z X_2$ |
|----------------|-------|-------|--------|--------|-------|-------------|
| F              | 118   | 215   | 249    | 209    | 175   | 255         |
| 0,             | 112   | 112   | 112    | 112    | 112   | 112         |
| O <sub>2</sub> | 255   | 126   | 126    | 126    | 126   | 126         |

TABLE 6(b)

|    | C1 C2 | C <sub>1</sub> C <sub>3</sub> | C1C4 | C1X1 | C1X2 | C1X3 |
|----|-------|-------------------------------|------|------|------|------|
| F  | 126   | 126                           | 126  | 126  | 126  | 126  |
| O, | 112   | 112                           | 112  | 120  | 116  | 114  |
| O, | 126   | 126                           | 126  | 255  | 255  | 255  |

TABLE 7(a) DOUBLE STUCK-AT FAULTS OUTPUTS FOR FUNCTION  $F_1$  WITH  $C_1$  AS ONE OF THE LINES FOR 1,0 COMBINATION

|    | C1 C2 | C, C | C,C4 | C <sub>1</sub> X <sub>1</sub> | C1X2 | C1X3 |
|----|-------|------|------|-------------------------------|------|------|
| F  | 38    | 120  | 94   | 32                            | 86   | 86   |
| O, | 0     | 0    | 0    | 0                             | 0    | 0    |
| O, | 255   | 255  | 255  | 255                           | 255  | 255  |

=

| Tabli | Ξ7( | b) |
|-------|-----|----|
|       |     |    |

| 0              | c, zl | c,za | c, za | c, za | C <sub>1</sub> ZX <sub>1</sub> | C <sub>1</sub> ZX <sub>2</sub> |
|----------------|-------|------|-------|-------|--------------------------------|--------------------------------|
| F              | 46    | 112  | 94    | 46    | 8                              | 0                              |
| 0              | 0     | 0    | 0     | 0     | 0                              | 0                              |
| O <sub>2</sub> | 126   | 255  | 255   | 255   | 255                            | 255                            |

#### TABLE 8(a)

DOUBLE STUCK-AT FAULTS OUTPUTS FOR FUNCTION  $F_1$ WITH  $C_1$  AS ONE OF THE LINES FOR 1.1 COMBINATION

|    | C1 C2 | CI C3 | C1 C4 | C1 X1 | C1 X2 | C1 X3 |
|----|-------|-------|-------|-------|-------|-------|
| F  | 38    | 6     | 38    | 38    | 34    | 36    |
| O, | 0     | 0     | 0     | 0     | 0     | 0     |
| O, | 255   | 255   | 255   | 255   | 255   | 255   |

| 8  | c, zl | c,za, | c, za <sub>2</sub> | c, za | C <sub>1</sub> ZX <sub>1</sub> | C <sub>1</sub> ZX <sub>2</sub> |
|----|-------|-------|--------------------|-------|--------------------------------|--------------------------------|
| F  | 118   | 143   | 161                | 209   | 247                            | 255                            |
| O, | 112   | 0     | 0                  | 0     | 0                              | 0                              |
| 0, | 255   | 255   | 255                | 255   | 255                            | 255                            |

TABLE 9 CONSOLIDATED RESULTS FOR DOUBLE STUCK-AT FAULTS

| S.No.                 | Function               | No. of data<br>Inputs | Total Possible<br>Faults | Identifiability<br>Factor (%) | Distinguishab<br>ility<br>Factor (%) |
|-----------------------|------------------------|-----------------------|--------------------------|-------------------------------|--------------------------------------|
| 1                     | F <sub>1</sub>         | 3                     | 312                      | 98.40                         | 30.13                                |
| 2                     | F2                     | 4                     | 544                      | 100                           | 31.25                                |
| 3                     | F <sub>3</sub>         | 5                     | 924                      | 99.89                         | 33.98                                |
| 4                     | F4                     | 6                     | 1404                     | 99.93                         | 33.26                                |
| 5                     | F <sub>5</sub>         | 7                     | 840                      | 100                           | 29.64                                |
| 6                     | F                      | 8                     | 3280                     | 100                           | 32.50                                |
| 7                     | F,                     | 9                     | 1860                     | 100                           | 32.80                                |
| 8                     | F                      | 10                    | 1984                     | 100                           | 31.50                                |
| 9                     | F.                     | 11                    | 1860                     | 100                           | 33.12                                |
| 10                    | <b>F</b> <sub>10</sub> | 12                    | 1984                     | 100                           | 31.10                                |
| 0 <del>0</del><br>181 |                        | erage                 | 5                        | 99.82                         | 31.93                                |

From the test results as given in Tables 4, and 9 it was found that the identifiability factor for the set of random functions tested through MATLAB simulation on an average was 90% for AND-bridging faults and almost 100% for Double stuck-at faults, with just n+5 test vectors compared to 2<sup>n</sup> test vectors required for conventional testing. It was also observed that the overall distinguishability factor was in the range of 30-58%, the individual set distinguishability factor was more than 94% as explained above. The plot for identifiability factor and distinguishability factor for AND-bridging and double stuck-at faults are given in Fig.3 and Fig.4.

Though the overall distinguishability is small, it does not affect the detection capability. Further, the distinguishing capability for an individual output set can be quite high, as illustrated in section 4.1



Fig.3 Percentage Identifiability Factor



Fig.4 Percentage DistinguishabilityFactor

## 5 CONCLUSION

A test set scheme for the detection of AND-bridging and double stuck-at faults for ESOP RMC logic functions have been detailed and the simulation results are shown. The results conclude that n+5 test vectors can be used to detect double stuck-at, and AND-bridging faults in digital circuits. Further, the location can also be diagnosed through the output sets. The analysis and diagnosis have been done through compact tabulation and two quantification indices considering all possible combinations of the data lines, control lines and all intermediate gate outputs line pairs. Detection and distinguishability factors can be further improved by modifying the network structure or using different test vectors.

#### REFERENCES

- Reddy S.M., "Easily Testable Realizations for Logic Functions", *IEEE Trans. on Computers*, vol.21, no.11, Nov.1972, pp. 1183-1188.
- [2] Pradhan D.K., "Universal Test Sets for Multiple Fault Detection in AND-EXOR Arrays", *IEEE Trans. on Computers*, vol.27, no.2, Feb.1978 pp. 181-187.
- [3] Bhattacharya B.B., Gupta B., Sarkar S and Choudhury A.K. "Testable design of RMC networks with universal tests for detecting stuck-at and bridging faults", *IEE Proc. Computers and Digital Techniques*, Vol.132, Part E., no.3, May 1985. pp. 155-162.
- [4] Sasao, T., "Easily Testable Realization for Reed-Muller Expressions", *IEEE Trans. on Computers*, vol.46, no.6, Jun.1997, pp. 709-716,.
- [5] Kalay U, Hall D.V. and Petrowski M.A., "A Minimal Universal Test Set for Self-Test of EXOR-Sum-of-Products Circuits", *IEEE Trans. on Computers*, vol.49, no.3, Mar.2000 pp. 267-276.
- [6] Zhongliang P., "Testable realizations of ESOP expressions of logic functions", Proc. of 11<sup>th</sup> Asian Test Symposium (ATS"02), *IEEE Computer Society*, 2002. Pp 140-144.
- [7] Zhongliang P., "Bridging fault detections for testable realizations of logic functions", Proc of 16<sup>th</sup> International Conference on VLSI Design, Jan. 2003, pp. 423-427.
- [8] Hafizur Rahaman, Debesh K.Dass, 'Bridging Fault Detection in Double Fixed-Polarity Reed-Muller (DFPRM) PLA' *IEEE Proceedings Asia and South Pacific Design Automation Conference* (ASP-DAC'05), 2005, pp 172-177.
- [9] Hafizur Rahaman, Debesh K.Dass, 'Universal Test Set for Detecting Stuckat and Bridging Faults in Double Fixed-Polarity Reed-Muller Programma-

ble Logic Arrays' IEE Proc.-Comput. Digit. Tech., Vol.153, No.2, March 2006. pp. 109-116.

- [10] Neelakantan P.N. and Ebenezer Jeyakumar A., "Stuck-at Fault Test Vectors for Exclusive-OR Sum Reed-Muller Canonical Boolean Functions", *GESTS International Transactions on Computer Science and Engineering*, Vol. 27, No.1, Jan. 2006 pp. 139-147.
- [11] Neelakantan P.N. and Jeyakumar A. E., "Single Stuck-At Fault Diagnosing Circuit of Reed-Muller Canonical Exclusive-Or Sum of Product Boolean Expressions", *Journal of Computer Science*, USA, Vol.2, Issue7, July 2006, pp. 595-599.
- [12] Pan Zhongliang and Chen Guangju, "Fault Detection Test Set for Testable Realizations of Logic Functions with ESOP Expressions", *Journal of Electronics* (China), Vol. 24(2), 2007, pp. 238-244.
- [13] Ling Chen, and Zhong Liang Pan, "Fault Detection of Bridging Faults in Digital Circuits by Shared Binary Decision Diagram", *Key Engineering Materials, Tans Tech Publications* (Volumes 439 - 440), June, 2010, pp. 1235-1240.
- [14] Wenjin Wu, Pengjun Wang, Xiaoying Zhang, Lingli Wang and Dai Jing "Search for the Best Polarity of Multi-Output RM Circuits Base on QGA", Second International Symposium on Intelligent Information Technology Application, Vol. 3, pp. 279 – 282, 2008.
- [15] Zhong Liang Pan, Ling Chen and Guang Zhao Zhang, "Test Pattern Generation of VLSI Circuits Using Hopfield Neural Networks", *Applied Mechanics and Materials, Trans Tech Publications* (Volumes 29 - 32), August, 2010, pp. 1034-1039.
- [16] Zhao Ying and Li Yanjuan, "A Multiple Faults Test Generation Algorithm Based on Neural Networks and Chaotic Searching For Digital Circuits", *International Conference on Computational Intelligence and Software Engineering* (CISE), December 2010.
- [17] Geetha V., Devarajan N. and Neelakantan P. N., "OR-Bridging Fault Identification and diagnosis for Exclusive-OR Sum of Products Reed-Muller Canonical Circuits", *Journal of Computer Science*, USA, Issue 7(5), July 2011, pp. 744-748.
- [18] Geetha V., Devarajan N. and Neelakantan P. N., "OR-Bridging Fault Analysis and Diagnosis for Exclusive-OR Sum of Products Reed-Muller Canonical Circuits", *European Journal of Scientific Research*, USA, Issue 71, No.4March 2012, pp. 482-489.